{% extends 'base_normal.html' %}
{% load static %}

{% block title %}用户登录 {% endblock %}

{% block css %}
    {# 加上边框css样式，自己写的，在css目录中 #}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
    {# 表单错误信息提示   #}
    <style>
        .error-msg {
            color: red;
        {# 不能让报错信息再占一行 #} position: absolute;
        {# 报错信息的字体大小 #} font-size: 12px;
        }
    </style>
{% endblock %}

{% block content %}
    <div class="account">
        <div class="title">用户登录</div>
        <form id="loginForm" method="post" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    {# 用一行来展示验证码和点击发送验证码  #}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row">
                            <div class="col-xs-7">
                                {{ field }}
                                {# 该span标签是为了显示报错信息,error-msg样式写在上边css块中 #}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-md-5">
                                <img src="{% url 'image_code' %}" id="imgCode" title="点击更换图片">
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        {# 该span标签是为了显示注册信息,error-msg样式写在上边css块中 #}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}
            <div>
                <div style="float: right;">
                    <a href="{% url 'login_sms' %}">短信验证码登录？</a>
                </div>
            </div>

            <div class="row">
                <div class="col-xs-3">
                    <input id="btnSubmit" type="button" class="btn btn-primary" value="登 录">
                </div>
            </div>
        </form>

    </div>
{% endblock %}


{% block js %}
    <script>
        //我一般喜欢做个封装
        $(function () {
            funchangeImage();
            loginStn();
        });

        /*
        更换图片验证码
        */

        function funchangeImage() {
            $('#imgCode').click(function () {
                //利用一个原理，url最后加？会刷新页面(重新访问)
                var oldSrc = $(this).attr('src');
                $(this).attr('src', oldSrc + "?")
            })
        }

        /*
        点击登录
         */
        function loginStn() {
            $('#btnSubmit').click(function () {
                //先要清空所有错误信息，每次点击后清空再显示错误，不能让用户改对了，你还一直显示着错误不动
                $('.error-msg').empty();
                //var username = $('#id_username').val();
                //var password = $('#id_password').val();
                //var code = $('#id_code').val();
                var data_list = $('#loginForm').serialize();
                $.ajax({
                    url: '{% url 'login' %}',
                    dataType: "json",
                    method: "post",
                    data: data_list,
                    success: function (res) {
                        if (res.status) {
                            location.href = res.data;
                        } else {
                            //{status:False,error:{mobile_phone:["错误信息"，]}}
                            //这个status就两个值，但是error是个列表，因为可能有多个字段校验不通过的情况
                            $.each(res.error, function (key, value) {
                                $("#id_" + key).next().text(value[0]);
                            })
                        }
                    }
                })
            })
        }


    </script>

{% endblock %}